package com.sojson.dao.impl;

import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

import javax.annotation.Resource;

import org.springframework.stereotype.Repository;

import com.sojson.base.impl.BaseDaoImpl;
import com.sojson.dao.ArticleDao;
import com.sojson.entity.bo.Select;
import com.sojson.entity.po.Article;

/**
 * 文章分类表Dao实现类(目的:把分页插件从Service层分离,这样就不用每次调Dao接口都要分页)
 * 
 * @author liu
 * @date 2021-03-16
 */
@Repository
public class ArticleDaoImpl extends BaseDaoImpl<ArticleDao, Article> implements ArticleDao {

    @Resource
    private ArticleDao articleDao;

    /**
     * 单条插入
     * 
     * @param article
     * @return
     * @throws SQLException
     */
    @Override
    public int insert(Article article) {
        return articleDao.insert(article);
    }

    /**
     * 批量插入
     * 
     * @param article
     * @return
     * @throws SQLException
     */
    @Override
    public int insertList(List<Article> articles) {
        return articleDao.insertList(articles);
    }

    /**
     * 通过对象批量删除(物理删除)
     * 
     * @param article
     * @return
     * @throws SQLException
     */
    @Override
    public int deleteByDto(Article article) {
        return articleDao.deleteByDto(article);
    }

    /**
     * 统计全部数量
     * 
     * @return
     * @throws SQLException
     */
    @Override
    public int countAll() {
        return articleDao.countAll();
    }

    /**
     * 查询所有
     * 
     * @return
     * @throws SQLException
     */
    @Override
    public List<Article> listAll() {
        return articleDao.listAll();
    }

    /**
     * 根据对象统计数量
     * 
     * @param article
     * @return
     * @throws SQLException
     */
    @Override
    public int countByDto(Article article) {
        return articleDao.countByDto(article);
    }

    /**
     * 根据对象查询
     * 
     * @param article
     * @return
     * @throws SQLException
     */
    @Override
    public List<Article> listByDto(Article article) {
        startPageDefaultSort(article);
        return articleDao.listByDto(article);
    }

    /**
     * 通过id删除(物理删除)
     * 
     * @param id
     * @return
     * @throws SQLException
     */
    @Override
    public int deleteById(Integer id) {
        return articleDao.deleteById(id);
    }

    /**
     * 通过id列表删除(物理删除)
     * 
     * @param ids
     * @return
     * @throws SQLException
     */
    @Override
    public int deleteByIdList(ArrayList<Integer> ids) {
        return articleDao.deleteByIdList(ids);
    }

    /**
     * 通过id更新(全部更新)
     * 
     * @param article
     * @return
     * @throws SQLException
     */
    @Override
    public int updateById(Article article) {
        return articleDao.updateById(article);
    }

    /**
     * 通过id列表更新(全部更新)(更新内容相同)
     * 
     * @param article
     * @return
     * @throws SQLException
     */
    @Override
    public int updateStaticByIdList(Article article) {
        return articleDao.updateStaticByIdList(article);
    }

    /**
     * 通过id列表更新(全部更新)(更新内容不相同)
     * 
     * @param articles
     * @return
     * @throws SQLException
     */
    @Override
    public int updateChangeByIdList(ArrayList<Article> articles) {
        return articleDao.updateChangeByIdList(articles);
    }

    /**
     * 通过id更新(局部更新)
     * 
     * @param article
     * @return
     * @throws SQLException
     */
    @Override
    public int updatePartialById(Article article) {
        return articleDao.updatePartialById(article);
    }

    /**
     * 通过id列表更新(局部更新)(更新内容相同)
     * 
     * @param article
     * @return
     * @throws SQLException
     */
    @Override
    public int updateStaticPartialByIdList(Article article) {
        return articleDao.updateStaticPartialByIdList(article);
    }

    /**
     * 通过id列表更新(局部更新)(更新内容不相同)
     * 
     * @param articles
     * @return
     * @throws SQLException
     */
    @Override
    public int updateChangePartialByIdList(ArrayList<Article> articles) {
        return articleDao.updateChangePartialByIdList(articles);
    }

    /**
     * 通过id查询
     * 
     * @param id
     * @return
     * @throws SQLException
     */
    @Override
    public Article findById(Integer id) {
        return articleDao.findById(id);
    }

    /**
     * 通过id列表查询
     * 
     * @param ids
     * @return
     * @throws SQLException
     */
    @Override
    public ArrayList<Article> findByIdList(ArrayList<Integer> ids) {
        return articleDao.findByIdList(ids);
    }

    /**
     * 通过对象查询id列表
     * 
     * @param article
     * @return
     * @throws SQLException
     */
    @Override
    public ArrayList<Integer> findIdByDto(Article article) {
        return articleDao.findIdByDto(article);
    }

    /**
     * 清空数据(物理清空)
     * 
     * @throws SQLException
     */
    @Override
    public void clear() {
        articleDao.clear();
    }

    /**
     * 根据对象查询
     * 
     * @param article
     * @return
     * @throws SQLException
     */
    @Override
    public List<Select> findSelect(Article article) {
        startPage(article);
        return articleDao.findSelect(article);
    }

}